

## University of Tehran

College of Engineering School of Electrical & Computer Engineering

# Experiment 4 Sessions 7,8

# **SOC** Clock Generation

Digital Logic Laboratory ECE 045 Laboratory Manual

Fall 1399



| D              | LDLab SOC Clock Generation | 1 |
|----------------|----------------------------|---|
| C              | Contents                   |   |
| C              | Contents                   | 1 |
| In             | ntroduction                | 2 |
| 1              | Exponential Accelerator    | 3 |
| 2              | Frequency Multiplier       | 4 |
| 3              | Integrated Circuit         | 5 |
| Acknowledgment |                            | 6 |



Figure 1: Block diagram of a typical integrated circuit

### Introduction

System on Chip is an integrated circuit that integrates multiple components including digital, analog, hardware and software programs all in a single chip. The main core of an SoC is a processor that handles different computational tasks within the system. In addition to the processor, the system includes a memory, Input/Output ports and accelerators.

As you have learned from the Digital Logic Design course, accelerators are dedicated computation units that usually execute one specific task. This single task, needs a smaller and less complicated datapath which leads to a high frequency of operation for the accelerators. This is in contrary to CPUs in which millions of operations must be executed within a fix time interval. This impose a low frequency of operation for CPUs. To increase the speed of an SOC, hardware accelerators are usually embedded in the system. The processor will dispute some of its tasks to hardware accelerator.

Since hardware accelerators have a higher frequency than the processor, there is a need for a frequency multiplier to multiply the processor frequency and feed it to the accelerators. In this way, while the processor is executing some sequential operations, the accelerator can execute multiple of operations with a higher frequency. This frequency multiplier is usually implemented with a Phased Lock Loop in real integrated systems. In this experiment you are going to design a frequency multiplier and use this in combination with an exponential accelerator.

By the end of this experiment, you should have learned:

- The concept of an SOC
- The concept of handshaking in an SoC
- The principle of an accelerator
- Processor and Accelerator timings

Figure 1 shows the block diagram of a typical integrated system including a processor and an accelerator. There is a handshaking between these two components via signals "start" and "done".

© Digital Logic Laboratory, University of Tehran, Fall 1399 Prepared and developed by Katayoon Basharkhah under supervision of Professor Z. Navabi

Integer Part Data Path Controller Done

Figure 2: Block diagram of exponential accelerator

The processor works with a frequency of 10 MHz. The accelerator which is a exponential can work with much higher frequency clock signal. This high frequency clock will be generated by a frequency multiplier module. Multiplication factor depends on the target accelerator that the clock is being generated for. There is a maximum frequency for each accelerator that is dominated by its worse case delay time. Considering this maximum frequency, the factor of frequency multiplication can be determined.

Accordingly, Below is the topics that are explained in the following of this experiment in details:

- Exponential Accelerator
- Frequency Multiplier Module
- Integrated System

#### 1 Exponential Accelerator

The accelerator that you are going to use is a exponential circuit. You are familiar with this accelerator design. As Figure 2 shows, this module receives a 16-bit input "x" and generates an 16bit output "Fractionalpart" and 2-bit "Integerpart". The accelerator starts working with a complete pulse on signal "start" and when the computation is completed signal "done" will be sent to the processor to acknowledge it. For the purpose of clock generation for this module, first you need to explore the design accuracy. Furthermore you as a designer need to be aware of the maximum frequency of this accelerator. The Verilog description code for this module is provided to you.

- 1. First examine the code and its accuracy by running Modelsim simulation. For this purpose, write a testbench for this design with at least three different values for input "x". Show the results by taking picture of the simulation results.
- 2. Synthesize this design in Quartus II Software. Show the synthesis results in your report.
- 3. After synthesizing design, you can find out the maximum frequency of this accelerator by referring to the Timing Analyzer reports in Quartus synthesis tool. You can follow the steps shown in the Figure 3



Figure 3: Steps for observing maximum frequency

#### 2 Frequency Multiplier

In this part, you are to design a frequency multiplier. Block diagram of this module is shown in Figure 4. A frequency multiplier takes an input signal frequency (InFreq with frequency f) and multiplies it by a value determined by multiplication factor (MultFactor). The output is a signal (OutFreq) with a frequency equal to InFreq\*MultFactor. Multiplication factor is a power of two and could be shown as  $2^n$ , where n is between 1 and 5. Therefore the circuit takes  $log_2MultFactor$ as the input value. For example if MultFactor is 8, the corresponding input value would be 3. InFreq frequency range is between 1MHz and 50MHz. A reference clock input is used for reference working clock of this circuit and is provided via an input named clock RefClk, with a high frequency of 150 MHz. The output of the circuit that carries the faster signal is outFreq. The frequency of this signal is  $f \times 2^n$ . The circuit has a valid output that is asserted when frequency multiplication is appearing on outFreq. When a positive pulse appears on "adjust", the circuit is informed of a new multiplication factor, and begins preparation for the multiplication process with this new factor. While this preparation is taking place, "valid" becomes 0 and remains 0 until preparation is complete at which time the generated out Freq signal represents the new multiplication factor. For this design, the following equation is true:

$$f \times 2^n = 150 \div k$$

For this you need first to calculate "k" value from the equation above. Remember that you need hardware components like counters and shifters to calculate this factor. After that, you can use factor "k" for dividing the high frequency (150MHz) reference clock and implementing the right hand side of equation above.

- 1. Show a state diagram of the controller.
- 2. Write the complete Verilog description of this design.

© Digital Logic Laboratory, University of Tehran, Fall 1399 Prepared and developed by Katayoon Basharkhah under supervision of Professor Z. Navabi



Figure 4: Block diagram of the frequency multiplier

- 3. In your top-level module, dedicate a part for the controller and one for the datapath.
- 4. Use Huffman coding style for the controller.
- 5. Use an asynchronous reset and a rising edge clock.
- 6. Write a testbench for your top-level design.
- 7. In your testbench provide different test sequence including at least three different values for input "n". show and calculate the output frequency from the simulation results.
- 8. Run the testbench in Modelsim simulation software and include the waveforms and results in your report.

#### 3 Integrated Circuit

In this part, you are to connected the accelerator and the frequency multiplier in an integrated circuit. For this purpose connect this two module based on the Figure 1. Although the accelerator is working with a higher frequency than the processor, for the handshaking signals of "start" and "done" the accelerator have to wait for the processor to send and recieve these signals with its low frequency. This imposes some timing overhead to the accelerator performance. This overhead can be defined as below:

$$Overhead = TAcc \div THsh$$

In which, T-Acc is the clock cycles for executing the accelerator computation and T-Hsh is the clock cycles waiting for hand shaking signals.

1. Connect the circuits of parts 1 and 2 in a top level design. The output of Frequency Multiplier would be the working clock of the accelerator.

© Digital Logic Laboratory, University of Tehran, Fall 1399 Prepared and developed by Katayoon Basharkhah under supervision of Professor Z. Navabi

- 2. You have find out the maximum frequency of the exponential accelerator in part 1. Based on this frequency and the frequency of the processor (10MHz), find the proper value range for "MultFactor" and input signal "n" in the frequency multiplier module. For example if the maximum frequency is 300 MHz then the "MultFactor" can take values up to 30.
- 3. Write a testbench and model the behavior of the processor in your testench. For this, you need to generate a CPU clock of 10 MHz. At first generate a complete pulse on signal "Adjust" and then a complete pulse on the signal "start" for the accelerator. Then provide the value for input "x". All these data and control signal values should be generated based on the CPU Clock. In this way, the frequency multiplier with the high frequency of 150 MHz generates the "Acc-clk" and accelerator starts working when receives start.
- 4. Inside your tesbench make a instantiation of the integrated top level design. Note that you should make an instance of the synthesized top-level design and include .sdo files in Modelsim simulation.
- 5. Test your design for different values of n within and outside the proper range of accelerator frequency. For example if the n is up to 30, provide values less than and also greater than 30 and verify the output result for all the cases.
- 6. Calculate the overhead of handshaking. Explain how a designer can reduce this overhead.

## Acknowledgment

This manual has been revised and edited by Zahra Jahanpeima, PHD student of Digital Systems at University of Tehran and Hadi Safari, undergraduate student of Computer Engineering at University of Tehran.